草庐IT

java mongo 数组列表保存

全部标签

ruby - 是否有特定的函数来检索然后删除随机数组元素?

我知道我可以通过几个步骤完成此操作,但想知道是否有可以实现此目的的函数。我想排列#sample,然后删除检索到的元素。 最佳答案 这个怎么样:array.delete_at(rand(array.length)) 关于ruby-是否有特定的函数来检索然后删除随机数组元素?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/10988525/

ruby - 从 Jekyll 插件返回目录中的文件列表?

我不知道如何在jekyll插件中创建过滤器或标签,以便我可以返回目录并循环遍历其内容。我找到了这些:http://pastebin.com/LRfMVN5Yhttp://snippets.dzone.com/posts/show/302到目前为止我有:moduleJekyllclassFilesTag我可以成功地将图像列表作为字符串返回并打印:{%filestest_string%}但对于我来说,无论我如何从Dir.glob返回数组/散列,我都无法遍历数组。我只想能够做到:{%forimageinfiles%}image{%endfor%}我将需要能够为我将在网站上使用的各种集合不断返

ruby-on-rails - Carreirwave - 如何直接从保存的文件名创建版本名称

我正在为已上传到我的应用程序的文件创建缩略图。图像名称中有一个时间戳代码。当我运行recreate_versions时,生成的缩略图也有时间戳,但它使用当前时间戳,这使得缩略图名称与原始文件名不同。所以我认为解决方法是为缩略图自定义文件名。基本上有'thumb_'+'原始文件名'。version:thumbdoprocess:resize_to_limit=>[110,nil]deffull_filename(for_file=model.image_value.file)'thumb_'+File.basename(model.image_value.path).to_sendend

ruby-on-rails - Ruby on Rails 在保存之前通过关联对象 has_many

在RubyonRails项目中,我试图在将所有内容保存到数据库之前访问ActiveRecord上的关联对象。classPurchase如果我像这样构建我的对象:purchase=Purchase.new(item_ids:[1,2,3])并尝试保存它item_validation方法还没有填充项目集合,所以即使虽然项目已经设置,但它没有机会调用任何项目的check_something方法。是否可以在我的购买模型和关联模型保留之前访问项目集合,以便我可以对它们运行验证?如果我将item_validation方法更改为:defitem_validationpurchase_items.ea

Ruby - 如何在不同线程上的每个数组元素上运行一个方法?

所以我有一个包含40000个元素的数组,我希望对每个元素运行一个方法。为了减少花费的时间,我正在考虑在多个线程上运行它。也许将数组拆分为多个数组并在不同的线程或其他东西上运行。但我不知道如何开始。假设数组是foo[],调用的方法是bar()。bar()返回一个字符串。代码执行后,我希望能够将所有字符串合并/添加到一个大字符串中。有没有办法做到这一点?我试图让我的问题尽可能简单,但如果您想了解更多信息,请告诉我。提前致谢! 最佳答案 听起来您想要类似pmap函数的东西。有一个名为peach的ruby库它在native数组上提供了pma

ruby-on-rails - Ruby 数组方法 assoc 和 associates 的目的是什么?

我已经阅读了Rubyarray的方法assoc和rassoc的文档。我明白他们在做什么。他们都在数组的数组上工作。assoc返回第一个元素等于提供的参数的数组,rassoc做同样的事情,但第二个元素。我的问题是这些方法有什么用?此功能非常具体。我猜想创建这些方法是有原因的。这是什么? 最佳答案 有几个原因,但主要的原因是数组可以像散列一样工作。我认为因为散列是未排序的,Ruby设计者需要一种方法来以有序的方式表示散列。我认为有很多Enumerable方法在哈希上调用时返回数组。 关于ru

ruby - 为什么即使在 Hash 上调用 Enumerable#find/#detect 也会返回一个数组?

documentationforEnumerable#find/#detect说:find(ifnone=nil){|obj|block}→objornilfind(ifnone=nil)→an_enumeratorPasseseachentryinenumtoblock.Returnsthefirstforwhichblockisnotfalse.Ifnoobjectmatches,callsifnoneandreturnsitsresultwhenitisspecified,orreturnsnilotherwise.但是在Hash上调用时,结果已经将类型改为Array,而不是原来

Ruby 相当于 perl 的 "Data::Dumper",用于打印深度嵌套的哈希/数组

这不是RubyequivalentofPerlData::Dumper的副本.这个问题已经超过3.5年了,因此想检查从那时起Ruby中是否有任何可用的新选项。我正在寻找perl的Dumper在ruby​​中的等价物。我不在乎Dumper在幕后做了什么。我已经广泛使用它在perl中打印深度嵌套的哈希和数组。到目前为止,我还没有在ruby​​中找到替代品(或者我可能没有找到一种方法来充分利用Ruby中的可用替代品)。这是我的perl代码及其输出:#!/usr/bin/perl-wusestrict;useData::Dumper;my$hash;$hash->{what}->{where}

ruby - 为什么在 Ruby 中屈服于 lambda splat 数组参数?

在Ruby中,使用错误数量的参数调用lambda会导致ArgumentError:l=lambda{|a,b|pa:a,b:b}l.call(1,2)#{:a=>1,:b=>2}l.call(1)#ArgumentError:wrongnumberofarguments(given1,expected2)传递数组也不起作用:(因为数组只是一个对象,对吧?)l.call([3,4])#ArgumentError:wrongnumberofarguments(given1,expected2)除非我使用splat(*)将数组转换为参数列表,但我没有。但是...如果我通过yield隐式调用l

ruby - 在 Ruby 中对哈希数组的值求和

我在想出添加哈希数组的优雅方法时遇到了麻烦[{:a=>1,:b=>2,:c=>3},{:a=>1,:b=>2,:c=>3},{:a=>1,:b=>2,:c=>3}]应该返回[{:a=>3,:b=>6,:c=>9}]我知道它可能会涉及映射/归约,但我想不出正确的语法,ruby-docdotorg与我的版本不匹配也无济于事我使用的是1.8.7 最佳答案 array.inject{|x,y|x.merge(y){|_,a,b|a+b}}(在Ruby1.8.7上验证) 关于ruby-在Ruby中